草庐IT

Java Iterator(迭代器)

全部标签

c++ - R 和 C++ 迭代

我正在尝试使用Rcpp从R编写一个在C++中运行循环的函数。我有一个矩阵Z,它比函数应该返回的矩阵OUT短一行,因为OUT第一行的每个位置都将由标量sigma_0给出。该函数应该实现一个微分方程。每次迭代都取决于矩阵Z的值以及矩阵OUT的先前生成值。我得到的是这个:cppFunction('NumericMatrixsim(NumericMatrixZ,longdoublesigma_0,longdoubledelta,longdoubleomega,longdoublegamma){intnrow=Z.nrow()+1,ncol=Z.ncol();NumericMatrixout(n

c++ - 如何获得非常量迭代器

std::mapdict;...autopmax=dict.begin();//hereigetconstiterator我可以“明确指出”获取的值是非常量类型吗? 最佳答案 如果您的dict不是const,begin将返回std::map::iterator.现在,关键是const,但值不是。auto应该给你一个std::map::iterator;你有相反的证据吗? 关于c++-如何获得非常量迭代器,我们在StackOverflow上找到一个类似的问题:

c++ - vector 迭代器的增量/减量

NicolaiJosuttis的“C++标准库”第9章:STL迭代器指出:以下可能无法在某些平台上编译:std::vectorcoll;//sort,startingwithsecondelement//-NONPORTABLEversionif(coll.size()>1){std::sort(++coll.begin(),col.end());}Dependingontheplatform,thecompilationof++col.begin()mightfail.However,ifyouuseforexample,adequeratherthanavector,thecomp

c++ - 使用 boost::filesystem 3.0 迭代文件

我想遍历目录中与“keyword.txt”匹配的所有文件。我在谷歌搜索了一些解决方案,发现了这个:CanIuseamasktoiteratefilesinadirectorywithBoost?我后来发现,“leaf()”函数已被替换(来源:http://www.boost.org/doc/libs/1_41_0/libs/filesystem/doc/index.htm->转到“已弃用的名称和功能”部分)到目前为止我得到的是这个,但它没有运行。很抱歉这个有点愚蠢的问题,但我或多或少是一个C++初学者。conststd::stringtarget_path("F:\\data\\");

c++ - tbb::concurrent_unordered_map::unsafe_erase 是否会使任何现有的迭代器失效?

我看到tbb::concurrent_unordered_map与std::unordered_map非常接近,同时对于并发是安全的。我也知道unsafe_erase对于insert等不是并发安全的。迭代器文档还声明任何现有的迭代器对于insert仍然有效,查找等问题是,unsafe_erase是否会使除被要求删除的迭代器之外的任何其他迭代器失效?std::unordered_map和std::map当然有这种行为,但它没有在任何地方的concurrent_unordered_map文档中指定。 最佳答案 tbb::unsafe_e

c++ - 使用带有 char * 的正则表达式迭代器

我正在尝试将文件读入缓冲区,然后使用正则表达式迭代器。我知道我可以将C++字符串迭代器与正则表达式迭代器一起使用(构造函数是std::regex_iterator),但我想避免将缓冲区复制到字符串中并继续使用低级函数来读取文件(现在我使用open()和read())。structstatbuff;intfile=open(argv[1],O_RDONLY);if(!file)cout我认为我的选择是找到一种使用read()的方法使用C++字符串而不是char*或在char数组上使用正则表达式迭代器的方法。我可以写一个,但我也在努力让我的程序尽可能小。有什么办法可以做到吗?如何将C++字

c++ - {} 是传递给需要迭代器(代表某个容器的 std::end() )的函数的有效参数吗?

在boostdirectory_iteratorexample-howtolistdirectoryfilesnotrecursive(参见thisanswer)中是示例代码#include#include#include...usingnamespaceboost::filesystem;for(auto&entry:boost::make_iterator_range(directory_iterator(p),{})){std::cout(p是boost::filesystem::path类型。)在查看documentationformake_iterator_range时,我认

c++ - 具有递归模板参数包函数是否为每次迭代创建特定函数?

假设我使用参数包重新创建printf:voidprintf(constchar*string){std::coutvoidprintf(constchar*string,Tfirst,Params...p){while(*string!='\0'){if(*string=='%'&&*(string+1)!='%'){std::cout我使用以下参数调用该函数:printf("%distheanswertolife,theuniverse,andeverything.Pi=%f",42,3.14);编译器会创建2个具有不同签名的不同函数吗?printf(constchar*,int,P

c++ - 删除结束迭代器是对标准的疏忽还是设计决策?

标准库容器允许我们删除由迭代器first和last表示的范围。std::vectorbar;//firstitlastitbar.erase(bar.begin(),bar.end());标准规定first迭代器必须有效并且可解引用,而last只需要有效。但是,如果first==last则first不需要取消引用,因为erase是空操作。这意味着以下内容是合法的:bar.erase(bar.end(),bar.end());但是,如果我只想删除一个元素而不是一个范围,则迭代器必须是有效的并且可解引用,从而导致以下未定义的行为:bar.erase(bar.end());为什么这不只是空操

c++ - 一个函数可以同时接受迭代器和反向迭代器作为参数吗

下面的代码在第二个函数调用中给我错误。我怎样才能让我的函数同时接受iterator和reverse_iterator作为参数,而不是使用vector::reverse_iterator等参数类型创建第二个函数#includeusingnamespacestd;voidtraverse(vector::iteratorbegin,vector::iteratorend,vector::iteratorsbegin,vector::iteratorsend,string::iteratorabegin,string::iteratoraend){intlast=-1;autoi=begin